import axios from 'axios'
import { Message } from 'element-ui'
import store from '@/store'
import router from '@/router'

const request = axios.create({
  baseURL: process.env.VUE_APP_BASE_URL,
  timeout: 20000 // request timeout
})

// 请求拦截器
request.interceptors.request.use(
  config => {
    if (!config.headers.Authorization && store.state.user.token) {
      config.headers.Authorization = `Bearer ${store.state.user.token}`
    }
    return config
  },
  error => {
    return Promise.reject(error)
  }
)

// 响应拦截器
request.interceptors.response.use(
  response => {
    // 处理接口返回状态码是200 但是请求失败的情况
    // 解构接口返回值中的 data message success
    // 根据success判断当前接口是否成功
    // 如果success === true直接讲接口返回值return
    // 如果success === false 使用element组件 + message字段提示用户
    const { success, message } = response.data
    if (success) {
      return response.data
    } else {
      Message.error(message)
      return Promise.reject(message)
    }
  },
  error => {
    // 当请求的状态码为401，说明token过期
    // 需要重新登录
    if (error.response.status === 401) {
      store.commit('user/REMOVE_TOKEN')
      router.push('/login')
    }
    return Promise.reject(error)
  }
)

export default request
